Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore(common): improve configuration detection for hextobin #12481

Merged
merged 3 commits into from
Oct 7, 2024

Conversation

ermshiperete
Copy link
Contributor

This improves #12440. The previous change was a bit fragile if we updated commander versions. This change now implements a better solution that doesn't rely on dependencies and their locations for detecting if we need to run the configure action for hextobin.

@keymanapp-test-bot skip

This improves #12440. The previous change was a bit fragile if we updated
commander versions. This change now implements a better solution that
doesn't rely on dependencies and their locations for detecting if we need
to run the `configure` action for hextobin.
@keymanapp-test-bot
Copy link

keymanapp-test-bot bot commented Sep 27, 2024

The previous attempt failed when building on Windows. Using node should
work everywhere.
@mcdurdin
Copy link
Member

Yes, this is more robust, and I see how you have set this up to work on win + mac + linux. I understand you are adding it as a postinstall script so that any npm ci anywhere in the tree will cause the .configured file to be created.

Conversely, if you rm -rf node_modules now, the configure action will no longer be run. So we win some, lose some.

And this issue is more systemic than just hextobin, of course. Do you see us doing the same thing for all node projects? My main concern is that the node script is a little bit of slightly icky boilerplate to copy everywhere.

If we moved the .configured file out of the build folder, and added it to the global .gitignore, then we could do it cross-platform without node:

  "postinstall": "echo configured > .configured"

@darcywong00 darcywong00 modified the milestones: A18S11, A18S12 Sep 28, 2024
Addresses code review comments.
@ermshiperete
Copy link
Contributor Author

Do you see us doing the same thing for all node projects?

This is only necessary for node projects that either have 1) a local node_modules directory, or 2) are a dependency for a project in another subtree (e.g. common/tools/hextobin being a dependency for projects under core, although in that case it also has a local node_modules). Reason for 1 is that the local node_modules might not exist after cleaning the subtree. Reason for 2 is that the global node_modules likely has a link to the no-longer existing build directory after cleaning the subtree.

Hmm, maybe it's necessary for all node projects that serve as a dependency? But so far I never had problems if the dependency was in the same subtree, but that might have been luck. We'll see...

@ermshiperete ermshiperete merged commit f083881 into master Oct 7, 2024
9 checks passed
@ermshiperete ermshiperete deleted the chore/common/configure branch October 7, 2024 14:24
@keyman-server
Copy link
Collaborator

Changes in this pull request will be available for download in Keyman version 18.0.122-alpha

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Archived in project
Development

Successfully merging this pull request may close these issues.

4 participants